<?php
/**
 * @Me模型 - 数据对象模型
 * @author jason <yangjs17@yeah.net>
 * @version TS3.0
 */
class GroupAtmeModel extends Model {

	protected $tableNmae = 'group_atme';
    protected $fields = array(0=>'atme_id',1=>'app',2=>'table',3=>'row_id',4=>'uid',5=>'gid','_pk'=>'atme_id');

    private $_app = null;                       // 所属应用
    private $_app_table = null;                 // 所属资源表
    private $_app_pk_field = null;              // 应用主键字段
    private $_at_regex = "/@(.+?)([\s|:]|$)/is";//"/@{uid=([^}]*)}/";    // @正则规则
	private $_at_field = 'uid';                 // @的资源字段

    /**
     * 设置所属应用
     * @param string $app 应用名称
     * @return object @对象
     */
    public function setAppName($app) {
        $this->_app = $app;
        return $this;
    }

    /**
     * 设置相关内容所存储的资源表
     * @param string $app_table 数据表名
     * @return object @对象
     */
    public function setAppTable($app_table) {
        $this->_app_table = $app_table;
        return $this;
    }

    /**
     * 设置@的相关正则规则
     * @param string $regex 正则规则
     * @return object @对象
     */
    public function setAtRegex($regex) {
    	$this->_at_regex = $regex;
    	return $this;
    }

    /**
     * 设置@的资源字段
     * @param string $field @的资源字段
     * @return object @对象
     */
    public function setAtField($field) {
    	$this->_at_field = $field;
    	return $this;
    }

    /**
     * 获取@Me列表 - 分页型
     * @param array $map 查询条件
     * @param string $order 排序条件，默认为atme_id DESC
     * @param integer $limit 结果集显示个数，默认为20
     * @return array @Me列表信息
     */
    public function getAtmeList($map = null, $order = 'atme_id DESC', $limit = 20) {
        !$map['app'] && $this->_app && ($map['app'] = $this->_app);
        !$map['table'] && $this->_app_table && ($map['table'] = $this->_app_table);
        $data = $this->where($map)->order($order)->findPage($limit);
        // 格式化数据
        foreach($data['data'] as &$v) {
        	$v = model('Source')->getSourceInfo($v['table'], $v['row_id'], false, $v['app']);
        }
        
        return $data;
    }
	
    /**
     * 添加@Me数据
     * @param string $content @Me的相关内容
     * @param integer $row_id 资源ID
     * @param array $extra_uids 额外@用户ID
     * @param array $less_uids 去除@用户ID
     * @return integer 添加成功后的@ID
     */
    public function addAtme($content, $row_id, $extra_uids = null, $less_uids = null, $gid) {
        // 去除重复，空值与自己
        $extra_uids = array_diff($extra_uids, array($GLOBALS['ts']['mid']));
        $extra_uids = array_unique($extra_uids);
        $extra_uids = array_filter($extra_uids);

        $less_uids[] = $GLOBALS['ts']['mid'];
        $less_uids = array_unique($less_uids);
        $less_uids = array_filter($less_uids);
        // 获取@用户的UID数组
    	$uids = $this->getUids($content, $extra_uids, $row_id, $less_uids);
    	//过滤非团队成员
    	$map['uid'] = array('in' , $uids);
    	$map['gid'] = $gid;
    	$map['status'] = 1;
    	$ismemberuid = D('Member')->where($map)->field('uid')->findAll();
    	$uids = getSubByKey( $ismemberuid , 'uid' );
    	
        // 添加@信息
        $result = $this->_saveAtme($uids, $row_id, $gid);

    	return $result;
    }

    /**
     * 更新最近@的人
     * @param string $content 原创微博内容
     */
	public function updateRecentAt( $content ){
		// 获取@用户的UID数组
        preg_match_all($this->_at_regex, $content, $matches);
    	$unames = $matches[1];
    	if ( $unames[0] ){
	    	$map = "uname in ('".implode("','",$unames)."') AND uid!=".$GLOBALS['ts']['mid'].' AND `is_audit`=1 AND `is_init`=1 AND `is_active`=1';
	    	$ulist = model('User')->where($map)->field('uid')->findall();
	    	$matchuids = getSubByKey($ulist,'uid');
	    	$userdata = model( 'UserData' );
	    	$value = $userdata->where('uid='.$GLOBALS['ts']['mid']." and `key`='user_recentat'")->field('value')->find();
	    	if ( $value ){
	    		$atdata = getSubByKey( unserialize( $value['value'] ) , 'uid');
	    		$atdata && $matchuids = array_merge( $matchuids , $atdata);
	    		$matchuids = array_unique( $matchuids );
	    		$matchuids = array_slice( $matchuids , 0 , 10 );
	    		$users = model( 'User' )->getUserInfoByUids( $matchuids );
	    		foreach ( $users as $v){
	    			if ( !$v['uid'] ){
	    				continue;
	    			}
	    			$udata[] = array('uid'=>$v['uid'],'uname'=>$v['uname'],'avatar_small'=>$v['avatar_small'],'search_key'=>$v['search_key']);
	    		}
	    		//更新userdata表里面的最近@的人的信息
	    		$userdata->setField('value' , serialize( $udata ) , "`key`='user_recentat' AND uid=".$GLOBALS['ts']['mid']);
	    	} else {
	    		$matchuids = array_slice( $matchuids , 0 , 10 );
	    		$users = model( 'User' )->getUserInfoByUids( $matchuids );
	    		foreach ( $users as $v){
	    			if ( !$v['uid'] ){
	    				continue;
	    			}
	    			$udata[] = array('uid'=>$v['uid'],'uname'=>$v['uname'],'avatar_small'=>$v['avatar_small'],'search_key'=>$v['search_key']);
	    		}
	    		$data['uid'] = $GLOBALS['ts']['mid'];
	    		$data['key'] = 'user_recentat';
	    		$data['value'] = serialize( $udata );
	    		$data['mtime'] = time();
	    		$userdata->add($data);
	    	}
    	}
	}
    
    /**
     * 获取@内容中的@用户
     * @param string $content @Me的相关内容
     * @param array $extra_uids 额外@用户UID
     * @param integer $row_id 资源ID
     * @param array $less_uids 去除@用户ID
     * @return array 用户UID数组
     */
    public function getUids($content, $extra_uids = null, $row_id, $less_uids = null) {
        // 正则匹配内容
    	preg_match_all($this->_at_regex, $content, $matches);
    	$unames = $matches[1];
    	$map = "uname in ('".implode("','",$unames)."')";
    	$ulist = model('User')->where($map)->field('uid')->findall();
    	$matchuids = getSubByKey($ulist,'uid');
        // 如果内容匹配中没有用户
        if(empty($matchuids) && !empty($extra_uids)) {
            // 去除@用户ID
            if(!empty($less_uids)) {
                foreach($less_uids as $k => $v) {
                    if(in_array($v, $extra_uids)) {
                        unset($extra_uids[$k]);
                    }
                }
            }
            return is_array($extra_uids) ? $extra_uids : array($extra_uids);
        }
        // 如果匹配内容中存在用户
        $suid = array();
        foreach($matchuids as $v) {
            !in_array($v, $suid) && $suid[] = (int)$v;
        }
        // 去除@用户ID
        if(!empty($less_uids)) {
            foreach($suid as $k => $v) {
                if(in_array($v, $less_uids)) {
                    unset($suid[$k]);
                }
            }
        }
// 		// 发邮件流程
//         $author = model('User')->getUserInfo($GLOBALS['ts']['mid']);
//         $content = model('Source')->getSourceInfo($this->_app_table, $row_id, false, $this->_app);
//         $config['content'] = parse_html($content['source_content']);
//         $config['publish_time'] = date('Y-m-d H:i:s',$content['ctime']);
//         $config['feed_url'] = U('public/Profile/feed',array('feed_id'=>$content['row_id'],'uid'=>$content['uid']));
//         $config['name'] = $author['uname'];
//         $config['space_url'] = $author['space_url'];   
//         $config['face'] = $author['avatar_middle'];
//         foreach($suid as $u_v) {
//             model('Notify')->sendNotify($u_v, 'atme', $config);
//         }
/*		if(in_array('atme',MailModel::$allowed)){
			foreach($suid as $u_v){
				$v = array('table'=>$this->_app_table,'app'=>$this->_app,'row_id'=>$row_id,'uid'=>$u_v);
				$toUser = model('User')->getUserInfo($u_v);
                $map['key'] = 'email';
                $map['uid'] = $u_v;
                $isEmail = D('user_privacy')->where($map)->field('value')->find();
                if($isEmail['value'] == 0){
    				$content = model('Source')->getSourceInfo($v['table'],$v['row_id'],false,$v['app']);
    				//model('Mail')->send_email($toUser['email'],'atme','',array('content'=>parse_html($content['source_content'])));
                    model('Mail')->send_email($toUser['email'],$author['uname'].'在微博中@提到了您',parse_html($content['source_content']));
                }
                unset($map);
                unset($isEmail);
			}
		}*/
        
		return array_unique(array_filter(array_merge($suid, (array)$extra_uids)));
    }

    /**
     * 删除@Me数据
     * @param string $content @Me的相关内容
     * @param integer $row_id 资源ID
     * @param array $extra_uids 额外@用户UID
     * @return boolean 是否删除成功
     */
    public function deleteAtme($content, $row_id, $extra_uids = null) {
        $uids = $this->getUids($content, $extra_uids);
        $result = $this->_deleteAtme($uids, $row_id);
        return $result;
    }

    /**
     * 添加@Me信息操作
     * @param array $uids 用户UID数组
     * @param integer $row_id 资源ID
     * @return integer 添加成功后的@ID
     */
	private function _saveAtme($uids, $row_id, $gid) {
		foreach ($uids as $u_v) {
			// 去除自己@自己的数据
			if($u_v == $GLOBALS['ts']['mid']) {
				continue; 
			}
			$data[] = "('{$this->_app}', '{$this->_app_table}', {$row_id}, {$gid}, {$u_v})";
            // 更新@Me的未读数目
            D('GroupUserCount')->addCount($u_v, 'atme', $gid ,1);
		}
        !empty($data) && $res = $this->query('INSERT INTO '.$this->tablePrefix.'group_atme (`app`, `table`, `row_id`, `gid`, `uid`) VALUES '.implode(',', $data));

		return $res;
	}

    /**
     * 删除@Me信息操作
     * @param array $uids 用户UID数组
     * @param integer $row_id 资源ID
     * @return boolean 是否删除成功
     */
    private function _deleteAtme($uids, $row_id) {
        $result = false;
        if(!empty($uids)) {
            $map['table'] = $this->_app_table;
            $map['row_id'] = $row_id;
            $map['uid'] = array('IN', $uids);
            $res = $this->where($map)->delete();
            $res !== false && $result = true;
        } else {
            $map['table'] = $this->_app_table;
            $map['row_id'] = $row_id;
            $res = $this->where($map)->delete();
            $res !== false && $result = true;
        }

        return $result;
    }

    /*** API使用方法 ***/
    // 所有的@信息
    public function mentions($mid , $since_id = 0 , $max_id = 0 , $limit = 20 , $page = 1, $table=null) {   
        $since_id = intval($since_id);
        $max_id = intval($max_id);
        $limit = intval($limit);
        $page = intval($page); 
        $where = "uid = '{$mid}'";
        if($table){   
            $where .= " AND `table`='{$table}' ";
        }
        if(!empty($since_id) || !empty($max_id)) {
            !empty($since_id) && $where .= " AND atme_id > {$since_id}";
            !empty($max_id) && $where .= " AND atme_id < {$max_id}";
        }
        $start = ($page - 1) * $limit;
        $end = $limit;
        $list = $this->where($where)->limit("$start, $end")->order('atme_id DESC')->findAll();

        foreach($list as $k => $v) {
            $list[$k] = model('Source')->getSourceInfo($v['table'], $v['row_id'], true, $v['app']);
            $list[$k]['atme_id'] = $v['atme_id'];
            //评论的内容
            $list[$k]['content'] = $list[$k]['source_content'];
            unset($list[$k]['source_content']);
        }

        return $list;
    }

    // 动态的@信息
    public function mentions_feed($mid , $since_id = 0 , $max_id = 0 , $limit = 20 , $page = 1) {
        $since_id = intval($since_id);
        $max_id = intval($max_id);
        $limit = intval($limit);
        $page = intval($page); 
        $where = "uid = '{$mid}' AND `table`='feed' ";
        if(!empty($since_id) ) {
            !empty($since_id) && $where .= " AND row_id > {$since_id}";
        }
        if(!empty($max_id)){
            !empty($max_id) && $where .= " AND row_id < {$max_id}";
        }
        $start = ($page - 1) * $limit;
        $end = $limit;
        $feed_ids = $this->where($where)->limit("$start, $end")->order('atme_id DESC')->field('row_id')->getAsFieldArray('row_id');
        $data = D('GroupFeed')->formatFeed($feed_ids,true); 
        return $data;
    }
}